package com.lh.jianzhioffer.专项练习.字符串;

import java.util.LinkedList;
import java.util.Queue;
import java.util.Stack;

/**
 * @author: linghao
 * @since: 2023/2/28
 *
 * 给定一个字符串 s ，请你找出其中不含有重复字符的 最长连续子字符串 的长度
 */
public class 不含重复字符的最长子字符串016 {

    public static void main(String[] args) {
        String str = "pwwkew";
        System.out.println(lengthOfLongestSubstring(str));
    }

    public static int lengthOfLongestSubstring(String s) {
        if(s == null || s.length()==0)return 0;
        Queue<Character> queue =  new LinkedList<>();
        int max = 0;
        char[] chars = s.toCharArray();
        for(char c : chars){
            while (queue.contains(c)){
                queue.poll();
            }
            queue.add(c);
            max = Math.max(max,queue.size());
        }
        return max;

    }

}
